<template>

  <el-cascader
    :value="value"
    :options="treeDate"
    :props="props"
    size="mini"
    separator="-"
    @change="changeValue"
  />

</template>

<script>
import { getDepartment } from '@/api/department'
import { listToTreeDate } from '@/utils'
export default {
  props: {
    value: {
      type: Number, // 这里存储的是部门的id
      default: null
    }
  },
  data() {
    return {
      treeDate: [],
      props: {
        value: 'id', // 要存储的字段
        label: 'name', // 要展示的字段
        children: 'children'
      }
    }
  },
  created() {
    this.getDepartment()
  },
  methods: {
    async getDepartment() {
      const result = await getDepartment()
      this.treeDate = listToTreeDate(result, 0)
    },
    changeValue(list) {
      // 取到数组的最后一个元素
      if (list.length > 0) {
        this.$emit('input', list[list.length - 1])// 最后一位的id取出来
      } else {
        this.$emit('input', null) // 如果没有选择部门，就把部门id设置为null
      }
    }
  }
}

</script>
